# CRT Controller # SY6545-1 # MICROPROCESSOR PRODUCTS - Single +5 volt (±5%) power supply. - Alphanumeric and limited graphics capabilities. - Fully programmable display (rows, columns, blanking, etc.). - Non-interlaced scan. - 50/60 Hz operation. - Fully programmable cursor. - External light pen capability. - Capable of addressing up to 16K character Video Display RAM. - No DMA required. - Pin-compatible with MC6845. - Row/Column or straight-binary addressing for Video Display RAM. - Internal status register. - Video Display RAM may be configured as part of microprocessor memory field or independently slaved to 6545 (Transparent Addressing). The SY6545-1 is a CRT Controller intended to provide capability for interfacing the 6500/6800 microprocessor families to CRT or TV-type raster scan displays. A unique feature is the inclusion of several modes of operation, so that the system designer can configure the system with a wide assortment of techniques. #### INTERFACE DIAGRAM #### ORDERING INFORMATION | Part Number | Package | | |-------------|---------|-------| | SYP6545-1 | Plastic | 1 MHz | | SYC6545-1 | Ceramic | 1 MHz | | SYD6545-1 | Cerdip | 1 MHz | | SYP6545A-1 | Plastic | 2 MHz | | SYC6545A-1 | Ceramic | 2 MHz | | SYD6545A-1 | Cerdip | 2 MHz | #### PIN DESIGNATION | 1 | $\cup$ | 40 | USANG | |----|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------| | 2 | | 39 | HSYNC | | 3 | | 38 | RA0 | | 4 | | 37 | RA1 | | 5 | | 36 | RA2 | | 6 | | 35 | □ RA3 | | 7 | | 34 | RA4 | | 8 | | 33 | □ DB0 | | 9 | SY6545-1 | 32 | □ DB1 | | 10 | | 31 | □ DB2 | | 11 | | 30 | DB3 | | 12 | | 29 | DB4 | | 13 | | 28 | DB5 | | 14 | | 27 | DB6 | | 15 | | 26 | DB7 | | 16 | | 25 | □ cs | | 17 | | 24 | RS | | 18 | | 23 | ] 02 | | 19 | | 22 | ∏ R/₩ | | 20 | | 21 | CCLK | | _ | | | , | | | 2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19 | 2<br>3<br>4<br>5<br>6<br>7<br>8<br>9 SY6545-1<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18 | 2 39 3 38 4 37 5 36 6 37 7 34 8 33 9 \$Y6545-1 32 10 30 11 30 12 29 13 28 14 27 15 26 16 25 17 24 18 23 19 22 | ## MAXIMUM RATINGS All inputs contain protection circuitry to prevent damage due to high static discharges. Care should be exercised to prevent unnecessary application of voltages in excess of the allowable limits. #### COMMENT Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability. # **D.C. CHARACTERISTICS** $(V_{CC} = 5.0V \pm 5\%, GND = 0V, T_A = 0 - 70^{\circ}C, unless otherwise noted)$ | Symbol | Characteristic | Min. | Max. | Unit | |------------------|---------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------|----------| | V <sub>IH</sub> | Input High Voltage | 2.4 | V <sub>CC</sub> | V | | VIL | Input Low Voltage | -0.3 | 0.4 | V | | I <sub>IN</sub> | Input Leakage (φ2, R/w, RES, CS, RS, LPEN, CCLK) | - | 2.5 | μΑ | | ITSI | Three-State Input Leakage (DB0-DB7) V <sub>IN</sub> = 0.4 to 2.4V | _ | ±10.0 | μΑ | | V <sub>OH</sub> | Output High Voltage $I_{LOAD} = -205\mu A \text{ (DB0-DB7)}$ $I_{LOAD} = -100\mu A \text{ (all others)}$ | 2.4 | _ | V | | V <sub>OL</sub> | Output Low Voltage I <sub>LOAD</sub> = 1.6mA | _ | 0.4 | ٧ | | P <sub>D</sub> | Power Dissipation (T <sub>A</sub> = 25°C), V <sub>CC</sub> = 5.25V | | 900 | mW | | C <sub>IN</sub> | Input Capacitance<br>\$\phi_2\$, R\script{\overline{W}}, \overline{\overline{RES}}, \overline{\overline{CS}}, RS, LPEN, CCLK DB0-DB7 | _<br>_ | 10.0<br>12.5 | pF<br>pF | | C <sub>OUT</sub> | Output Capacitance | _ | 10.0 | pF | ## **TEST LOAD** # MPU BUS INTERFACE CHARACTERISTICS # WRITE TIMING CHARACTERISTICS ( $V_{CC} = 5.0V \pm 5\%$ , $T_A = 0-70^{\circ}$ C, unless otherwise noted) | | · | SY6 | 545-1 | SY65 | | | |------------------|----------------------|------|-------|------|------|------| | Symbol | Characteristic | Min. | Max. | Min. | Max. | Unit | | t <sub>CYC</sub> | Cycle Time | 1.0 | _ | 0.5 | _ | μs | | t <sub>C</sub> | φ2 Pulse Width | 440 | | 200 | _ | ns | | t <sub>ACW</sub> | Address Set-Up Time | 180 | _ | 90 | | ns | | <sup>t</sup> caH | Address Hold Time | 0 | _ | 0 - | | ns | | twcw | R/W Set-Up Time | 180 | _ | 90 – | | ns | | t <sub>CWH</sub> | R/W Hold Time | 0 | _ | 0 | _ | ns | | t <sub>DCW</sub> | Data Bus Set-Up Time | 265 | _ | 100 | _ | ns | | t <sub>HW</sub> | Data Bus Hold Time | 10 | _ | 10 | | ns | $(t_r \text{ and } t_f = 10 \text{ to } 30 \text{ ns})$ # READ TIMING CHARACTERISTICS ( $V_{CC} = 5.0 \text{V} \pm 5\%$ , $T_A = 0-70^{\circ}\text{C}$ , unless otherwise noted) | | | SY6 | 545-1 | SY65 | | | |------------------|-------------------------------------|------|-------|------|------|------| | Symbol | Characteristic | Min. | Max. | Min. | Max. | Unit | | t <sub>CYC</sub> | Cycle Time | 1.0 | _ | 0.5 | | μs | | t <sub>C</sub> | φ2 Pulse Width | 440 | _ | 200 | _ | ns | | tACR | Address Set-Up Time | 180 | _ | 90 | _ | ns | | tCAR | Address Hold Time | 0 | _ | 0 | _ | ns | | twcr | R/W Set-Up Time | 180 | | 90 | _ | ns | | tCDR | Read Access Time (Valid Data) | - | 340 | _ | 150 | ns | | tHR | Read Hold Time | 10 | _ | 10 | - | ns | | t <sub>CDA</sub> | Data Bus Active Time (Invalid Data) | 40 | | 40 | | ns | $(t_r \text{ and } t_f = 10 \text{ to } 30 \text{ ns})$ # MEMORY AND VIDEO INTERFACE CHARACTERISTICS ( $V_{CC}$ = 5.0V $\pm$ 5%, $T_A$ = 0 to 70°C, unless otherwise noted) ## SYSTEM TIMING # TRANSPARENT ADDRESSING $(\phi_1/\phi_2 \text{ INTERLEAVING})$ | | | SY6 | 545-1 | SY654 | | | |---------------------|----------------------------------|------|-------|-------|------|------| | Symbol | Characteristic | Min. | Max. | Min. | Max. | Unit | | tccy | Character Clock Cycle Time | 0.40 | 40 | 0.40 | 40 | μs | | t <sub>CCH</sub> | Character Clock Pulse Width | 200 | | 200 | | ns | | (X)t <sub>MAD</sub> | MA0-MA13 Propagation Delay | - | 300 | - | 300 | ns | | (X)t <sub>RAD</sub> | RAO-RA4 Propagation Delay | _ | 300 | - | 300 | ns | | (X)t <sub>DTD</sub> | DISPLAY ENABLE Propagation Delay | _ | 450 | _ | 450 | ns | | (X)t <sub>HSD</sub> | HSYNC Propagation Delay | _ | 450 | - | 450 | ns | | (X)t <sub>VSD</sub> | VSYNC Propagation Delay | _ | 450 | - | 450 | ns | | (X)t <sub>CDD</sub> | CURSOR Propagation Delay | | 450 | _ | 450 | ns | | t <sub>TAD</sub> | MA0-MA13 Switching Delay | | 200 | | 200 | ns | # LIGHT PEN STROBE TIMING NOTE: "Safe" time position for LPEN positive edge to cause address n+2 to load into Light Pen Register. $t_{LP2}$ and $t_{LP1}$ are time positions causing uncertain results. | | | SY6 | 545-1 | SY65 | | | |------------------|--------------------|------|-------|------|------|------| | Symbol | Characteristic | Min. | Max. | Min. | Max. | Unit | | tLPH | LPEN Hold Time | 150 | | 150 | _ | ns | | t <sub>LP1</sub> | LPEN Setup Time | 20 | _ | 20 | | ns | | t <sub>LP2</sub> | CCLK to LPEN Delay | 0 | | 0 | _ | ns | $t_r$ , $t_f = 20$ ns (max) # MPU INTERFACE SIGNAL DESCRIPTION φ2 (Clock) The input clock is the system $\phi 2$ clock and is used to trigger all data transfers between the system microprocessor and the SY6545. Since there is no maximum limit to the allowable $\phi 2$ cycle time, it is not necessary for it to be a continuous clock. This capability permits the SY6545 to be easily interfaced to non-6500-compatible microprocessors. #### R/W (Read/Write) The $R\overline{\mathcal{M}}$ signal is generated by the microprocessor and is used to control the direction of data transfers. A high on the $R\overline{\mathcal{M}}$ pin allows the processor to read the data supplied by the SY6545; a low on the $R\overline{\mathcal{M}}$ pin allows a write to the SY6545. #### CS (Chip Select) The Chip Select input is normally connected to the processor address bus either directly or through a decoder. The SY6545 is selected when $\overline{CS}$ is low. #### RS (Register Select) The Register Select input is used to access internal registers. A low on this pin permits writes into the Address Register and reads from the Status Register. The contents of the Address Register is the identity of the register accessed when RS is high. #### DB<sub>0</sub>-DB<sub>7</sub> (Data Bus) The $DB_0 \cdot DB_7$ pins are the eight data lines used for transfer of data between the processor and the SY6545. These lines are bi-directional and are normally high-impedance except during read cycles when the chip is selected. # VIDEO INTERFACE SIGNAL DESCRIPTION HSYNC (Horizontal Sync) The HSYNC signal is an active-high output used to determine the horizontal position of displayed text. It may drive a CRT monitor directly or may be used for composite video generation. HSYNC time position and width are fully programmable. #### VSYNC (Vertical Sync) The VSYNC signal is an active-high output used to determine the vertical position of displayed text. Like HSYNC, VSYNC may be used to drive a CRT monitor or composite video generation circuits. VSYNC position and width are both fully programmable. #### **DISPLAY ENABLE** The DISPLAY ENABLE signal is an active-high output and is used to indicate when the SY6545 is generating active display information. The number of horizontal displayed characters and the number of vertical displayed characters are both fully programmable and together are used to generate the DISPLAY ENABLE signal. DISPLAY ENABLE may be delayed by one character time by setting bit 4 of R8 to a "1". #### CURSOR The CURSOR signal is an active-high output and is used to indicate when the scan coincides with the programmed cursor position. The cursor position may be programmed to be any character in the address field. Furthermore, within the character, the cursor may be programmed to be any block of scan lines, since the start scan line and the end scan line are both programmable. The CURSOR position may be delayed by one character time by setting bit 5 of R8 to a "1". #### LPEN The LPEN signal is an edge-sensitive input and is used to load the internal Light Pen Register with the contents of the Refresh Scan Counter at the time the active edge occurs. The active edge of LPEN is the low-to-high transition. #### CCLK The CCLK signal is the character timing clock input and is used as the time base for all internal count/control functions. #### RES The RES signal is an active-low input used to initialize all internal scan counter circuits. When RES is low, all internal counters are stopped and cleared, all scan and video outputs are low, and control registers are unaffected. RES must stay low for at least one CCLK period. All scan timing is initiated when RES goes high. In this way, RES can be used to synchronize display frame timing with line frequency. # MEMORY ADDRESS SIGNAL DESCRIPTION MA0-MA13 (Video Display RAM Address Lines) These signals are active-high outputs and are used to address the Video Display RAM for character storage and display operations. The starting scan address is fully programmable and the ending scan address is determined by the total number of characters displayed, which is also programmable, in terms of characters/line and lines/frame There are two selectable address modes for MA0-MA13: #### Binary Characters are stored in successive memory locations. Thus, the software must be developed so that row and column co-ordinates are translated to sequentially-numbered addresses for video display memory operations. #### Row/Column In this mode, MA0-MA7 function as column addresses CC0-CC7, and MA8-MA13, as row addresses CR0-CR5. In this case, the software may handle addresses in terms of row and column locations, but additional address compression circuits are needed to convert CCO-CC7 and CR0-CR5 into a memory-efficient binary scheme. #### RA0-RA4 (Raster Address Lines) These signals are active-high outputs and are used to select each raster scan within an individual character row. The number of raster scan lines is programmable and determines the character height, including spaces between character rows. The high-order line, RA4, is unique in that it can also function as a strobe output pin when the SY6545 is programmed to operate in the "Transparent Address Mode". In this case the strobe is an active-high output and is true at the time the Video Display RAM update address is gated on to the address lines, MA0-MA13. In this way, updates and readouts of the Video Display RAM can be made under control of the SY6545 with only a small amount of external circuitry. ## **DESCRIPTION OF INTERNAL REGISTERS** Figure 1 illustrates the format of a typical video display and is necessary to understand the functions of the various SY6545 internal registers. Figure 2 illustrates vertical and horizontal timing. Figure 3 summarizes the internal registers and indicates their address selection and read/write capabilities. #### Address Register This is a 5-bit register which is used as a "pointer" to direct SY6545 data transfers to and from the system MPU. Its contents is the number of the desired register (0-31). When RS is low, then this register may be loaded; when RS is high, then the register selected is the one whose identity is stored in this register. #### Status Register This 3-bit register is used to monitor the status of the ### CRTC, as follows: #### Horizontal Total (R0) This 8-bit register contains the total of displayed and non-displayed characters, minus one, per horizontal line. The frequency of HSYNC is thus determined by this register. ## Horizontal Displayed (R1) This 8-bit register contains the number of displayed characters per horizontal line. #### Horizontal Sync Position (R2) This 8-bit register contains the position of the HSYNC on the horizontal line, in terms of the character location number on the line. The position of the HSYNC determines the left-to-right location of the displayed text on the video screen. In this way, the side margins are adjusted. Figure 1. Video Display Format 5 #### Horizontal and Vertical SYNC Widths (R3) This 8-bit register contains the widths of both HSYNC and VSYNC, as follows: \*IF BITS 4-7 ARE ALL "0", THEN VSYNC WILL BE 16 SCAN LINES WIDE. Control of these parameters allows the SY6545 to be interfaced to a variety of CRT monitors, since the HSYNC and VSYNC timing signals may be accommodated without the use of external one-shot timing. #### Vertical Total (R4) The Vertical Total Register is a 7-bit register containing the total number of character rows in a frame, minus one. This register, along with R5, determines the overall frame rate, which should be close to the line frequency to ensure flicker-free appearance. If the frame time is adjusted to be longer than the period of the line frequency, then RES may be used to provide absolute synchronism. | | | Ac | ldr | ess | Re | g. | Reg. | | | | | | | Reç | giste | er 8 | Bit | | | |----|----|----|-----|-----|----|----|------|---------------------------|-----------------------------------|--------|------------------|----------------|----------------|----------------|----------------|------|-------|----------------|--------| | cs | RS | 4 | 3 | 2 | 1 | 0 | No. | Register Name | Stored Info. | RD | WR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1 | _ | - | - | - | - | - | - | | | | | | W, | W, | III | III | /// | $/\!\!/\!\!/$ | $\eta$ | | 0 | 0 | - | - | - | - | - | _ | Address Reg. | Reg. No. | | | | | M | A <sub>4</sub> | Аз | $A_2$ | Αı | Αc | | 0 | 0 | - | - | - | - | - | _ | Status Reg. | | -V | | U | L | ٧ | III | M | M | II | | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | R0 | Horiz, Total – 1 | # Charac. | | $\vee$ | • | • | • | • | • | • | • | • | | 0 | 1 | 0 | 0 | 0 | 0 | 1 | R1 | Horiz. Displayed | # Charac. | | $\vee$ | • | • | • | • | • | • | • | • | | 0 | 1 | 0 | 0 | 0 | 1 | 0 | R2 | Horiz. Sync<br>Position | # Charac. | | $\vee$ | • | • | • | • | • | • | • | • | | 0 | 1 | 0 | 0 | 0 | 1 | 1 | R3 | VSYNC, HSYNC<br>Widths | # Scan Lines and<br># Char. Times | | V | V <sub>3</sub> | V <sub>2</sub> | V <sub>1</sub> | V <sub>0</sub> | Нз | Н2 | H <sub>1</sub> | н | | 0 | 1 | 0 | 0 | 1 | 0 | 0 | R4 | Vert. Total - 1 | # Charac. Row | | $\vee$ | M | • | • | • | • | • | • | • | | 0 | 1 | 0 | 0 | 1 | 0 | 1 | R5 | Vert. Total Adjust | # Scan Lines | | $\vee$ | M | $/\!\!/$ | W | • | • | • | • | • | | 0 | 1 | 0 | 0 | 1 | 1 | 0 | R6 | Vert. Displayed | # Charac. Rows | | $\vee$ | M | • | • | • | • | • | • | • | | 0 | 1 | 0 | 0 | 1 | 1 | 1 | R7 | Vert. Sync Position | # Charac. Rows | | $\vee$ | M | • | • | • | • | • | • | • | | 0 | 1 | 0 | 1 | 0 | 0 | 0 | R8 | Mode Control | | | $\vee$ | • | • | • | • | • | • | • | • | | 0 | 1 | 0 | 1 | 0 | 0 | 1 | R9 | Scan Lines - 1 | # Scan Lines | | | | M | M | • | • | • | • | • | | 0 | 1 | 0 | 1 | 0 | 1 | 0 | R10 | Cursor Start | Scan Line No. | | $\vee$ | | B₁ | B <sub>0</sub> | • | • | • | • | • | | 0 | 1 | 0 | 1 | 0 | 1 | 1 | R11 | Cursor End | Scan Line No. | | $\lceil \rceil$ | | W | $V_{I}$ | • | • | • | • | • | | 0 | 1 | 0 | 1 | 1 | 0 | 0 | R12 | Display Start<br>Addr (H) | | - | V | | | • | • | • | • | • | • | | 0 | 1 | 0 | 1 | 1 | 0 | 1 | R13 | Display Start<br>Addr (L) | | | <b>√</b> | • | • | • | • | • | • | • | • | | 0 | 1 | 0 | 1 | 1 | 1 | 0 | R14 | Cursor Position (H) | | | $\checkmark$ | | W | • | • | • | • | • | • | | 0 | 1 | 0 | 1 | 1 | 1 | 1 | R15 | Cursor Position (L) | | $\neg$ | $\checkmark$ | • | • | • | • | • | • | • | • | | 0 | 1 | 1 | 0 | 0 | 0 | 0 | R16 | Light Pen Reg (H) | | | | M | W | • | • | • | • | • | • | | 0 | 1 | 1 | 0 | 0 | 0 | 1 | R17 | Light Pen Reg (L) | | $\vee$ | | • | • | • | • | • | • | • | ŀ | | 0 | 1 | 1 | 0 | 0 | 1 | 0 | R18 | Update Address<br>Reg (H) | | | <b>√</b> | | | • | • | • | • | • | • | | 0 | 1 | 1 | 0 | 0 | 1 | 1 | R19 | Update Address<br>Reg (L) | | | <b>√</b> | • | • | • | • | • | • | • | • | | 0 | 1 | 1 | 1 | 1 | 1 | 1 | R31 | Dummy Location | | | | | M | $M_{I}$ | M | | M | M | 1 | Notes: - Designates binary bit - Designates unused bit. Reading this bit is always "0", except for R31, which does not drive the data bus at all, and for CS = "1" which operates likewise. Figure 3. Internal Register Summary #### Vertical Total Adjust (R5) The Vertical Total Adjust Register is a 5-bit write only register containing the number of additional scan lines needed to complete an entire frame scan and is intended as a fine adjustment for the video frame time. #### Vertical Displayed (R6) This 7-bit register contains the number of displayed character rows in each frame. In this way, the vertical size of the displayed text is determined. #### Vertical Sync Position (R7) This 7-bit register is used to select the character row time at which the VSYNC pulse is desired to occur and, thus, is used to position the displayed text in the vertical direction. #### Mode Control (R8) This register is used to select the operating modes of the SY6545 and is outlined as follows: #### Scan Line (R9) This 5-bit register contains the number of scan lines per character row, including spacing, minus 1. #### Cursor Start (R10) and Cursor End (R11) These 5-bit registers select the starting and ending scan lines for the cursor. In addition, bits 5 and 6 of R10 are used to select the cursor mode, as follows: | В | IIT | CURSOR MORE | |---|-----|--------------------------| | 6 | 5 | CURSOR MODE | | 0 | 0 | No Blinking | | 0 | 1 | No Cursor | | 1 | 0 | Blink at 1/16 field rate | | 1 | 1 | Blink at 1/32 field rate | Note that the ability to program both the start and end scan line for the cursor enables either block cursor or underline to be accommodated. Registers R14 and R15 are used to control the character position of the cursor over the entire 16K address field. ## Display Start Address High (R12) and Low (R13) These registers together comprise a 14-bit register whose contents is the memory address of the first character of the displayed scan (the character on the top left of the video display, as in Figure 1). Subsequent memory addresses are generated by the SY6545 as a result of CCLK input pulses. Scrolling of the display is accomplished by changing R12 and R13 to the memory address associated with the first character of the desired line of text to be displayed first. Entire pages of text may be scrolled or changed as well via R12 and R13. ## Cursor Position High (R14) and Low (R15) These registers together comprise a 14-bit register whose contents is the memory address of the current cursor position. When the video display scan counter (MA lines) matches the contents of this register, and when the scan line counter (RA lines) falls within the bounds set by R10 and R11, then the CURSOR output becomes active. Bit 5 of the Mode Control Register (R8) may be used to delay the CURSOR output by a full CCLK time to accommodate slow access memories. #### LPEN High (R16) and Low (R17) These registers together comprise a 14-bit register whose contents is the light pen strobe position, in terms of the video display address at which the strobe occurred. When the LPEN input changes from low to high, then, on the next negative-going edge of CCLK, the contents of the internal scan counter is stored in registers R16 and R17. #### Update Address High (R18) and Low (R19) These registers together comprise a 14-bit register whose contents is the memory address at which the next read or update will occur (for transparent address mode, only). Whenever a read/update occurs, the update location automatically increments to allow for fast updates or readouts of consecutive character locations. This is described elsewhere in this document. #### **Dummy Location (R31)** This register does not store any data, but is required to detect when transparent addressing updates occur. This is necessary to increment the Update Address Register and to set the Update Ready bit in the status register. #### **DETAILED DESCRIPTION OF OPERATION** #### Register Formats Register pairs R12/R13, R14/R15, R16/R17, and R18/R19 are formatted in one of two ways: - 1. Straight binary if register R8, bit 2 is a "0". - Row/Column if register R8, bit 2 is a "1". In this case the low byte is the Character Column and the high byte is the Character Row. Figure 4 illustrates the address sequence for the video display control for each mode. Note from Figure 4 that the straight-binary mode has the advantage that all display memory addresses are stored in a continuous memory block, starting with address 0 and ending at 1919. The disadvantage with this method is that, if it is desired to change a displayed character location, the row and column identity of the location must be converted to its binary address before the memory may be written. The row/column mode, on the other hand, does not need to undergo this conversion. However, memory is not used as efficiently, since the memory addresses are not continuous, but gaps exist. This requires that the system be equipped with more memory than is actually used and this extra memory is wasted. Alternatively, address compression logic may be employed to translate the row/column format into a continuous address block. In this way, the user may select whichever mode is best for the given application. The trade-offs between the modes are software versus hardware. Straight-binary mode minimizes hardware requirements and row/column requires minimum software. STRAIGHT BINARY ADDRESSING SEQUENCE ROW/COLUMN ADDRESSING SEQUENCE Figure 4. Display Address Sequences (with Start Address = 0) for 80 x 24 Example #### Video Display RAM Addressing There are two modes of addressing for the video display memory: #### 1. Shared Memory In this mode the memory is shared between the MPU address bus and the SY6545 address bus. For this case, memory contention must be resolved by means of external timing and control circuits. Both the MPU and the SY6545 must have access to the video display RAM and the contention circuits must resolve this multiple access requirement. Figure 5 illustrates the system configuration. #### 2. Transparent Memory Addressing For this mode, the display RAM is not directly accessible by the MPU, but is controlled entirely by the SY6545. All MPU accesses are made via the SY6545 and a small amount of external circuits. Figure 6 shows the system configuration for this approach. Figure 5. Shared Memory System Configuration Figure 6. Transparent Memory Addressing System Configuration (Data Hold Latch needed for Horizontal/Vertical Blanking updates, only). From the diagram of Figure 5, it is clear that both the SY6545 and the system MPU must be capable of addressing the video display memory. The SY6545 repetitively fetches character information to generate the video signals in order to keep the screen display active. The MPU occasionally accesses the memory to change the displayed information or to read out current data characters. Three ways of resolving this dual-contention requirement are apparent: #### MPU Priority In this technique, the address lines to the video display memory are normally driven by the SY6545 unless the MPU needs access, in which case the MPU addresses immediately override those from the SY6545 and the MPU has immediate access. #### φ1/φ2 Memory Interleaving This method permits both the SY6545 and the MPU access to the video display memory by time-sharing via the system $\phi 1$ and $\phi 2$ clocks. During the $\phi 1$ portion of each cycle (the time when $\phi 2$ is low), the SY6545 address outputs are gated to the video display memory. In the $\phi$ 2 time, the MPU address lines are switched in. In this way, both the SY6545 and the MPU have unimpeded access to the memory. Figure 7 illustrates the timings. Figure 7. $\phi 1/\phi 2$ Interleaving #### Vertical Blanking With this approach, the address circuitry is identical to the case for MPU Priority updates. The only difference is that the Vertical Retrace status bit (bit 5 of the Status Register) is used by the MPU so that access to the video display memory is only made during vertical blanking time (when bit 5 is a "1"). In this way, no visible screen perturbations result. #### Transparent Memory Addressing In this mode of operation, the video display memory address lines are not switched by contention circuits, but are generated by the SY6545. In effect, the contention is handled by the SY6545. As a result, the schemes for accomplishing MPU memory access are different: #### φ1/φ2 Interleaving This mode is similar to the Interleave mode used with shared memory. In this case, however, the $\phi 2$ address is generated from the Update Address Register (Registers R18 and R19) in the SY6545. Thus, the MPU must first load the address to be accessed into R18/R19 and then this address is always gated onto the MA lines during $\phi$ 2. Figure 8 shows the timing. Figure 8. $\phi 1/\phi 2$ Transparent Interleaving ## • Horizontal/Vertical Blanking In this mode, the Update Address is loaded by the MPU, but is only gated onto the MA lines during horizontal or vertical blank times, so memory accesses do not interfere with the display appearance. To signal when the update address is on the MA lines, an update strobe (STB) is provided as an alternate function of pin 34. Data hold latches are necessary to temporarily retain the character to be stored until the retrace time occurs. In this way, the system MPU is not halted waiting for the blanking time to arrive. Figure 9 illustrates the address and strobe timing for this mode. Transparent address modes are quite complex and offer significant advantages in system implementation. The details of their application are covered thoroughly in related Technical Notes available from Synertek. Figure 9. Retrace Update Timings # Cursor and Display Enable Skew Control Bits 4 and 5 of the Mode Control register (R8) are used to delay the Display Enable and Cursor outputs, respectively. Figure 10 illustrates the effect of the delays. Figure 10. Cursor and Display Enable Skew Figure 11. Operation of Vertical Blanking Status Bit